home *** CD-ROM | disk | FTP | other *** search
/ PC Player 2004 May / pc player 2004-05.iso / Demos / FarCry / Data1.cab / _B98FE88DABEB4DD6AD06D2D54E6D2871 < prev    next >
Encoding:
Text File  |  2004-01-06  |  1.5 KB  |  45 lines

  1.       #include "../CGVPMacro.csi"
  2.  
  3.       PS20Only
  4.  
  5.       MainInput { uniform sampler2D baseMap : register(s0),
  6.                   uniform sampler2D bumpMap : register(s1),
  7.                   uniform sampler2D attenMap : register(s2),
  8.                   uniform float4 Diffuse,
  9.                   uniform float4 Specular }
  10.       DeclarationsScript
  11.       {
  12.         OUT_T0_T1_T2_T3_T4_C0
  13.         FOUT
  14.       }
  15.       CoreScript
  16.       {
  17.         // load the decal
  18.         half4 decalColor = tex2D(baseMap, IN.Tex0.xy);
  19.         // load the bump normal
  20.         float4 bumpNormal = 2*(tex2D(bumpMap, IN.Tex1.xy)-0.5);
  21.  
  22.         half atten = saturate((2*(IN.Color.b-0.5)) * -(2*(IN.Color.b-0.5)) + (1-tex2D(attenMap, IN.Tex2.xy).b));
  23.  
  24.         // normalize post-filtered bump normals
  25.         bumpNormal.xyz = normalize(bumpNormal.xyz);
  26.  
  27.         // normalize light vector
  28.         float3 lightVec = normalize(IN.Tex3.xyz);
  29.         float fDif = saturate(dot(lightVec.xyz, bumpNormal.xyz));
  30.  
  31.         // normalize view vector
  32.         float3 viewVec = normalize(IN.Tex4.xyz);
  33.         float3 reflVec = (2*dot(lightVec.xyz, bumpNormal.xyz)*bumpNormal.xyz)-lightVec.xyz;
  34.         float NdotR = saturate(dot(reflVec.xyz, viewVec.xyz));
  35.         half fSpec = pow(NdotR, Specular.w);
  36.  
  37.         half3 dif = (decalColor.xyz * fDif * atten * Diffuse.xyz) * 2;
  38.         half3 spec = (fSpec * atten * Specular.xyz) * 2;
  39.  
  40.         // finally add them all together
  41.         OUT.Color.xyz = dif + spec;
  42.         OUT.Color.w = decalColor.w * Diffuse.w;
  43.       }
  44.  
  45.